# MICROS 32 BITS STM - OC

ROBINSON JIMENEZ MORENO









#### 23.3.8 Output compare mode

This function is used to control an output waveform or indicating when a period of time has elapsed.

When a match is found between the capture/compare register and the counter, the output compare function:

- Assigns the corresponding output pin to a programmable value defined by the output compare mode (OCxM bits in the TIMx\_CCMRx register) and the output polarity (CCxP bit in the TIMx\_CCER register). The output pin can keep its level (OCXM=000), be set active (OCxM=001), be set inactive (OCxM=010) or can toggle (OCxM=011) on match.
- Sets a flag in the interrupt status register (CCxIF bit in the TIMx\_SR register).
- Generates an interrupt if the corresponding interrupt mask is set (CCXIE bit in the TIMx\_DIER register).
- Sends a DMA request if the corresponding enable bit is set (CCxDE bit in the TIMx\_DIER register, CCDS bit in the TIMx\_CR2 register for the DMA request selection).

The TIMx\_CCRx registers can be programmed with or without preload registers using the OCxPE bit in the TIMx\_CCMRx register.

In output compare mode, the update event UEV has no effect on ocxref and OCx output. The timing resolution is one count of the counter. Output compare mode can also be used to output a single pulse (in One-pulse mode).

#### Procedure

- 1. Select the counter clock (internal, external, prescaler).
- 2. Write the desired data in the TIMx\_ARR and TIMx\_CCRx registers.
- Set the CCxIE and/or CCxDE bits if an interrupt and/or a DMA request is to be generated.
- 4. Select the output mode. For example, you must write OCxM=011, OCxPE=0, CCxP=0 and CCxE=1 to toggle OCx output pin when CNT matches CCRx, CCRx preload is not used, OCx is enabled and active high.
- 5. Enable the counter by setting the CEN bit in the TIMx CR1 register.

The TIMx\_CCRx register can be updated at any time by software to control the output waveform, provided that the preload register is not enabled (OCxPE=0, else TIMx\_CCRx shadow register is updated only at the next update event UEV). An example is given in *Figure 236*.









# 23.4.1 TIMx control register 1 (TIMx\_CR1)

Address offset: 0x00

Reset value: 0x0000

| 15   | 14   | 13   | 12   | 11           | 10   | 9   | 8     | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0   |
|------|------|------|------|--------------|------|-----|-------|------|----|----|-----|-----|-----|------|-----|
| Res. | Res. | Res. | Res. | UIFRE<br>MAP | Res. | CKD | [1:0] | ARPE | CI | MS | DIR | OPM | URS | UDIS | CEN |
|      |      |      |      | rw           |      | rw  | rw    | rw   | rw | rw | rw  | rw  | rw  | rw   | rw  |
|      |      |      |      |              |      |     |       |      |    |    |     |     |     |      |     |

Bit 0 CEN: Counter enable

0: Counter disabled
1: Counter enabled

Note: External clock, gated mode and encoder mode can work only if the CEN bit has been previously set by software. However trigger mode can set the CEN bit automatically by hardware.

CEN is cleared automatically in one-pulse mode, when an update event occurs.



# 23.4.7

# TIMx capture/compare mode register 1 (TIMx\_CCMR1)/CCMR2

Address offset: 0x18

Reset value: 0x0000

The channels can be used in input (capture mode) or in output (compare mode). The direction of a channel is defined by configuring the corresponding CCxS bits. All the other bits of this register have a different function in input and in output mode. For a given bit, OCxx describes its function when the channel is configured in output, ICxx describes its function when the channel is configured in input. So you must take care that the same bit can have a different meaning for the input stage and for the output stage.

| 31    | 30   | 29       | 28   | 27    | 26     | 25   | 24          | 23    | 22   | 21       | 20   | 19    | 18     | 17   | 16          |
|-------|------|----------|------|-------|--------|------|-------------|-------|------|----------|------|-------|--------|------|-------------|
| Res.  | Res. | Res.     | Res. | Res.  | Res.   | Res. | OC2M<br>[3] | Res.  | Res. | Res.     | Res. | Res.  | Res.   | Res. | OC1M<br>[3] |
|       |      |          |      |       |        |      | Res.        |       |      |          |      |       |        |      | Res.        |
|       |      |          |      |       |        |      | rw          |       |      |          |      |       |        |      | rw          |
| 15    | 14   | 13       | 12   | 11    | 10     | 9    | 8           | 7     | 6    | 5        | 4    | 3     | 2      | 1    | 0           |
| OC2CE | (    | OC2M[2:0 | )]   | OC2PE | OC2FE  | 000  | 2[4:0]      | OC1CE | (    | OC1M[2:0 | ]    | OC1PE | OC1FE  | 0019 | 214.01      |
|       | IC2F | [3:0]    |      | IC2PS | C[1:0] | 002  | S[1:0]      |       | IC1F | [3:0]    |      | IC1PS | C[1:0] | COR  | S[1:0]      |
| rw    | rw   | rw       | rw   | rw    | rw     | rw   | rw          | rw    | rw   | rw       | rw   | rw    | rw     | rw   | rw          |





| 31    | 30     | 29       | 28     | 27    | 26      | 25   | 24          | 23    | 22   | 21       | 20   | 19    | 18     | 17   | 16          |
|-------|--------|----------|--------|-------|---------|------|-------------|-------|------|----------|------|-------|--------|------|-------------|
| Res.  | Res.   | Res.     | Res.   | Res.  | Res.    | Res. | OC2M<br>[3] | Res.  | Res. | Res.     | Res. | Res.  | Res.   | Res. | OC1M<br>[3] |
|       |        |          |        |       |         |      | Res.        |       |      |          |      |       |        |      | Res.        |
|       |        |          |        |       |         |      | rw          |       |      |          |      |       |        |      | rw          |
| 15    | 14     | 13       | 12     | 11    | 10      | 9    | 8           | 7     | 6    | 5        | 4    | 3     | 2      | 1    | 0           |
| OC2CE | (      | OC2M[2:0 | ]      | OC2PE | OC2FE   | CCO  | S[1:0]      | OC1CE | (    | OC1M[2:0 | )]   | OC1PE | OC1FE  | CC19 | S[1:0]      |
|       | IC2F   | [3:0]    |        | IC2PS | SC[1:0] | 002  | נט.ו ןכ     |       | IC1F | [3:0]    |      | IC1PS | C[1:0] | COL  | 5[1.0]      |
| rw    | rw     | rw       | rw     | rw    | rw      | rw   | rw          | rw    | rw   | rw       | rw   | rw    | rw     | rw   | rw          |
| 1111  |        |          |        |       |         |      | BIN         | 0     | 0    | 1        | 1    | 0     | 0      | 0    | 0           |
| Bit   | ts 6:4 | OC1M:    | Output | compa | re 1 mo | ode  | OX          |       |      | 3        |      |       | (      | )    |             |

These bits define the behavior of the output reference signal OC1REF from which OC1 and OC1N are derived. OC1REF is active high whereas OC1 and OC1N active level depends on CC1P and CC1NP bits.

0000: Frozen - The comparison between the output compare register TIMx\_CCR1 and the counter TIMx\_CNT has no effect on the outputs.(this mode is used to generate a timing base).

0001: Set channel 1 to active level on match. OC1REF signal is forced high when the counter TIMx\_CNT matches the capture/compare register 1 (TIMx\_CCR1).

0010: Set channel 1 to inactive level on match. OC1REF signal is forced low when the counter TIMx\_CNT matches the capture/compare register 1 (TIMx\_CCR1).

0011: Toggle - OC1REF toggles when TIMx\_CNT=TIMx\_CCR1.

0100: Force inactive level - OC1REF is forced low.

0101: Force active level - OC1REF is forced high.





#### Bit 3 OC1PE: Output compare 1 preload enable

 Preload register on TIMx\_CCR1 disabled. TIMx\_CCR1 can be written at anytime, the new value is taken in account immediately.

 Preload register on TIMx\_CCR1 enabled. Read/Write operations access the preload register. TIMx\_CCR1 preload value is loaded in the active register at each update event.

Note: 1: These bits can not be modified as long as LOCK level 3 has been programmed (LOCK bits in TIMx\_BDTR register) and CC1S=00 (the channel is configured in output).

2: The PWM mode can be used without validating the preload register only in onepulse mode (OPM bit set in TIMx\_CR1 register). Else the behavior is not guaranteed.

#### Bit 2 OC1FE: Output compare 1 fast enable

This bit is used to accelerate the effect of an event on the trigger in input on the CC output. 0: CC1 behaves normally depending on counter and CCR1 values even when the trigger is ON. The minimum delay to activate CC1 output when an edge occurs on the trigger input is 5 clock cycles.

1: An active edge on the trigger input acts like a compare match on CC1 output. Then, OC is set to the compare level independently from the result of the comparison. Delay to sample the trigger input and to activate CC1 output is reduced to 3 clock cycles. OCFE acts only if the channel is configured in PWM1 or PWM2 mode.

#### Bits 1:0 CC1S: Capture/Compare 1 selection

This bit-field defines the direction of the channel (input/output) as well as the used input.

00: CC1 channel is configured as output.

01: CC1 channel is configured as input, IC1 is mapped on TI1.

10: CC1 channel is configured as input, IC1 is mapped on TI2.

11: CC1 channel is configured as input, IC1 is mapped on TRC. This mode is working only if an internal trigger input is selected through TS bit (TIMx\_SMCR register)

Note: CC1S bits are writable only when the channel is OFF (CC1E = 0 in TIMx\_CCER).







# 23.4.9 TIMx capture/compare enable register (TIMx\_CCER)

Address offset: 0x20

Reset value: 0x0000

| 15    | 14   | 13   | 12   | 11    | 10   | 9    | 8    | 7     | 6    | 5    | 4    | 3     | 2    | 1    | 0    |
|-------|------|------|------|-------|------|------|------|-------|------|------|------|-------|------|------|------|
| CC4NP | Res. | CC4P | CC4E | CC3NP | Res. | CC3P | CC3E | CC2NP | Res. | CC2P | CC2E | CC1NP | Res. | CC1P | CC1E |
| rw    |      | rw   | rw   |

Bit 3 CC1NP: Capture/Compare 1 output Polarity.

CC1 channel configured as output: CC1NP must be kept cleared in this case.

**CC1 channel configured as input**: This bit is used in conjunction with CC1P to define TI1FP1/TI2FP1 polarity. refer to CC1P description.

Bit 1 CC1P: Capture/Compare 1 output Polarity.

CC1 channel configured as output:

0: OC1 active high

1: OC1 active low

Bit 0 CC1E: Capture/Compare 1 output enable.

CC1 channel configured as output:

0: Off - OC1 is not active

1: On - OC1 signal is output on the corresponding output pin

**CC1 channel configured as input**: This bit determines if a capture of the counter value can actually be done into the input capture/compare register 1 (TIMx\_CCR1) or not.

0: Capture disabled

1: Capture enabled

Note:

The state of the external IO pins connected to the standard OCx channels depends on the OCx channel state and the GPIO and AFIO registers.





# 23.4.10 TIMx counter (TIMx\_CNT)

Address offset: 0x24

Reset value: 0x0000

| 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23        | 22         | 21   | 20 | 19 | 18 | 17 | 16 |
|-------------------------|----|----|----|----|----|----|----------|-----------|------------|------|----|----|----|----|----|
| CNT[31]<br>or<br>UIFCPY |    |    |    |    |    | CN | T[30:16] | (dependir | ng on time | ers) |    |    |    |    |    |
| rw or r                 | rw | rw | rw | rw | ſW | rw | rw       | rw        | rw         | rw   | rw | rw | rw | rw | rw |
| 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8        | 7         | 6          | 5    | 4  | 3  | 2  | 1  | 0  |
|                         |    |    |    |    |    |    | CNT[     | 15:0]     |            |      |    |    |    |    |    |
| rw                      | rw | rw | rw | rw | rw | rw | rw       | rw        | rw         | rw   | rw | rw | rw | rw | rw |

Bits 30:16 CNT[30:16]: Most significant part counter value (on TIM2 and TIM5)

Bits 15:0 CNT[15:0]: Least significant part of counter value



# 23.4.11 TIMx prescaler (TIMx\_PSC) Address offset: 0x28

Reset value: 0x0000

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

| _ |    |    |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
|---|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|   |    |    |    |    |    |    |    | PSCI | [15:0] |    |    |    |    |    |    |    |
| ⊢ |    |    |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
|   | rw   | rw     | rw | rw | rw | rw | rw | rw | rw |
| L |    |    |    |    |    |    |    |      |        |    |    |    |    |    |    |    |

#### Bits 15:0 PSC[15:0]: Prescaler value

The counter clock frequency CK\_CNT is equal to f<sub>CK\_PSC</sub> / (PSC[15:0] + 1).

PSC contains the value to be loaded in the active prescaler register at each update event (including when the counter is cleared through UG bit of TIMx\_EGR register or through trigger controller when configured in "reset mode").









## 23.4.4 TIMx DMA/Interrupt enable register (TIMx\_DIER)

Address offset: 0x0C

Reset value: 0x0000

| 15   | 14  | 13   | 12    | 11    | 10    | 9     | 8   | 7    | 6   | 5    | 4     | 3     | 2     | 1     | 0   |
|------|-----|------|-------|-------|-------|-------|-----|------|-----|------|-------|-------|-------|-------|-----|
| Res. | TDE | Res. | CC4DE | CC3DE | CC2DE | CC1DE | UDE | Res. | TIE | Res. | CC4IE | CC3IE | CC2IE | CC1IE | UIE |
|      | rw  |      | rw    | rw    | rw    | rw    | rw  |      | rw  |      | rw    | rw    | rw    | rw    | rw  |

Bit 4 CC4IE: Capture/Compare 4 interrupt enable

0: CC4 interrupt disabled.1: CC4 interrupt enabled.

Bit 3 CC3IE: Capture/Compare 3 interrupt enable

0: CC3 interrupt disabled.1: CC3 interrupt enabled.

Bit 2 CC2IE: Capture/Compare 2 interrupt enable

0: CC2 interrupt disabled.1: CC2 interrupt enabled.

Bit 1 CC1IE: Capture/Compare 1 interrupt enable

0: CC1 interrupt disabled.1: CC1 interrupt enabled.

Bit 0 UIE: Update interrupt enable

0: Update interrupt disabled.1: Update interrupt enabled.







# 23.4.12 TIMx auto-reload register (TIMx\_ARR)

Address offset: 0x2C

Reset value: 0xFFFF FFFF

| 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24        | 23        | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|--------|-----------|-----------|---------|----|----|----|----|----|----|
|    |    |    |    |    |    | ARR[31 | :16] (dep | ending or | timers) |    |    |    |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |
| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8         | 7         | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |        | ARR       | [15:0]    |         |    |    |    |    |    |    |
| rw     | rw        | rw        | rw      | rw | rw | rw | rw | rw | rw |

Bits 31:16 ARR[31:16]: High auto-reload value (on TIM2 and TIM5)

Bits 15:0 ARR[15:0]: Low Auto-reload Prescaler value

ARR is the value to be loaded in the actual auto-reload register.

Refer to the Section 23.3.1: Time-base unit on page 706 for more details about ARR update and behavior.

The counter is blocked while the auto-reload value is null.



# 23.4.13 TIMx capture/compare register 1 (TIMx\_CCR1)

Address offset: 0x34

Reset value: 0x0000

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24         | 23       | 22         | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|------------|----------|------------|------|------|------|------|------|------|
|      |      |      |      |      |      | CCR1[ | 31:16] (de | epending | on timers) |      |      |      |      |      |      |
| rw/r  | rw/r       | rw/r     | rw/r       | rw/r | rw/r | rw/r | rw/r | rw/r | rw/r |
| 15   | 14   | 13   | 12   | 11   | 10   | 9     | 8          | 7        | 6          | 5    | 4    | 3    | 2    | 1    | 0    |
|      |      |      |      |      |      |       |            |          |            |      |      |      |      |      |      |
|      |      |      |      |      |      |       | CCF        | R1[15:0] |            |      |      |      |      |      |      |

Bits 31:16 CCR1[31:16]: High Capture/Compare 1 value (on TIM2 and TIM5)

Bits 15:0 CCR1[15:0]: Low Capture/Compare 1 value

## If channel CC1 is configured as output:

CCR1 is the value to be loaded in the actual capture/compare 1 register (preload value). It is loaded permanently if the preload feature is not selected in the TIMx\_CCMR1 register (bit OC1PE). Else the preload value is copied in the active capture/compare 1 register when an update event occurs.

The active capture/compare register contains the value to be compared to the counter TIMx\_CNT and signaled on OC1 output.







Address offset: 0x44

Reset value: 0x0000 0000

Access: no wait state, word, half-word and byte access.

| 31   | 30           | 29         | 28         | 27           | 26         | 25         | 24         | 23     | 22     | 21           | 20           | 19   | 18          | 17          | 16         |
|------|--------------|------------|------------|--------------|------------|------------|------------|--------|--------|--------------|--------------|------|-------------|-------------|------------|
| Res. | Res.         | Res.       | Res.       | Res.         | LTDC<br>EN | Res.       | Res.       | SAI2EN | SAI1EN | SPI6EN       | SPI5EN       | Res. | TIM11<br>EN | TIM10<br>EN | TIM9<br>EN |
|      |              |            |            |              | rw         |            |            | rw     | rw     | rw           | rw           |      | rw          | rw          | rw         |
| 15   | 14           | 13         | 12         | 11           | 10         | 9          | 8          | 7      | 6      | 5            | 4            | 3    | 2           | 1           | 0          |
| Res. | SYSCFG<br>EN | SPI4<br>EN | SPI1<br>EN | SDMMC1<br>EN | ADC3<br>EN | ADC2<br>EN | ADC1<br>EN | Res.   | Res.   | USART6<br>EN | USART1<br>EN | Res. | Res.        | TIM8<br>EN  | TIM1<br>EN |
|      | rw           | rw         | rw         | rw           | rw         | rw         | rw         |        |        | rw           | ΓW           |      |             | rw          | rw         |

Bit 0 TIM1EN: TIM1 clock enable

This bit is set and cleared by software.

0: TIM1 clock disabled

1: TIM1 clock enabled







| Tal | ole | 12. | ST | M32F | 745xx | a |
|-----|-----|-----|----|------|-------|---|
|-----|-----|-----|----|------|-------|---|

|     |      |      |     |               | DIE 12       | . 5111132                       | F/45XX 8           |
|-----|------|------|-----|---------------|--------------|---------------------------------|--------------------|
|     |      |      | AF0 | AF1           | AF2          | AF3                             | AF4                |
|     | Po   | ort  | sys | TIM1/2        | 1M3/4/5      | TIM8/9/10/<br>11/LPTIM<br>1/CEC | I2C1/2/3/<br>4/CEC |
|     |      | PB9  | -   | -             | ΓΙΜ4_C<br>H4 | TIM11_CH<br>1                   | I2C1_SD<br>A       |
|     |      | PB10 | -   | TIM2_C<br>H3  | -            | -                               | I2C2_SC<br>L       |
|     |      | PB11 | -   | TIM2_C<br>H4  | -            | -                               | I2C2_SD<br>A       |
| Poi | rt B | PB12 | -   | TIM1_B<br>KIN | -            | -                               | I2C2_SM<br>BA      |
|     |      | PB13 | -   | TIM1_C<br>H1N | -            | -                               | -                  |

# 6.4.10 GPIO alternate function high register (GPIOx\_AFRH) (x = A..J)

Address offset: 0x24

Reset value: 0x0000 0000

| 31         | 30 | 29 | 28 | 27         | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|------------|----|----|----|------------|----|----|----|------------|----|----|----|------------|----|----|----|
| AFR15[3:0] |    |    |    | AFR14[3:0] |    |    |    | AFR13[3:0] |    |    |    | AFR12[3:0] |    |    |    |
| rw         | rw | rw | rw |
| 15         | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
| AFR11[3:0] |    |    |    | AFR10[3:0] |    |    |    | AFR9[3:0]  |    |    |    | AFR8[3:0]  |    |    |    |
| rw         | rw | rw | rw |
|            | •  |    |    |            |    |    |    |            |    |    | •  |            |    | •  |    |

Bits 31:0 **AFRy[3:0]:** Alternate function selection for port x pin y (y = 8..15)

These bits are written by software to configure alternate function I/Os

#### AFSELy selection:

| 0000: AF0  | 1000: AF8      |
|------------|----------------|
| 0001: AF1  | 1001: AF9      |
| 0010: AF2  | 1010: AF10     |
| 0011: AF3  | 1011: AF11     |
| 0100: AF4  | 1100: AF12     |
| 0101: AF5  | 1101: AF13     |
| 0440- 4 00 | 111∩ · Λ □ 1 / |









```
main_adc.cpp
 1 #include "STM32F7xx.h"
 2 - int main(void) {
 3
    unsigned int cont=0;
    RCC->AHB1ENR =0xFF; //Puertos A,B,C,D,E,F,G,H
    //CONFIGURACION TIM2 - CHANNEL 3 (PB10) - OUTPUT COMPARE
    RCC->APBIENR |= (1UL << 0); // Enable clock for TIM2
     TIM2->ARR = 800; // autoreload + prescaler 1 seg a 16MHz
     TIM2->PSC = 20000;
     TIM2->CCMR2 \mid = 0x30; //OC3M =011 - toggle
10
11
     TIM2->CCER |= (1UL << 8); //CC3NP=0; OC3 active high, CC3E = on
    GPIOB->MODER \mid= 0x200001;
12
13
    TIM2->CR1 \mid = (1UL << 0); //Counter enable
14
15
     while(true) {
16
17
            GPIOB->ODR = ~GPIOB->ODR; //led OFF
18
            for(int dato=0;dato<100000;dato++);</pre>
19
20
21
```

